查看原文
其他

逆向Google Voice设备OBi200 (二)

2017-10-21 StrokMitream 看雪学院

在本文的第一部分,我详细介绍了对OBi200的固件分析和获取root Shell的过程。在本文,我将展示区分串口针脚及利用串口获取控制台访问。



串口通信协议



回忆一下上篇文章中监听/dev/ttyS0的串口:


这是一个非常赞的开端,其透露出两点信息:第一,这明确了其串口为 8250 UART(典型的4针脚接口),极大地缩小了我们的搜索范围;第二,其指明了该接口的波特率,这些是与该端口通信所必须的条件。



鉴别针脚



尽管UART接口并未在业界形成统一的标准,但是要区分出OBi200上潜在的接口还是很容易的:



从上图可以看到,除了一个名为J17 的4 针模块,其他大多数测试点都已标记完好。由于最右边的那个针脚是方形的,暂且将它命名为1号吧。


现在只剩这几个针脚,接下来要做的就是区分这些UART针脚看,我已经准备好了USB UART转换器:



我首先开始找出接地端。用万用表连续测量各个针脚对RJ45外壳的电压,我迅速地确定4号引脚为接地:



搞定了1个,剩下的是略显复杂的另外3个脚的区分。为此,我专门测量了在设备启动过程中这3个脚的直流电压(详细过程请浏览这篇文章),结果如下:

      >1号脚电压在启动过程中从2.3V到3.2V波动

      >2号脚电压恰巧维持在略低于3.2V

      >3号脚为3.3V 恒定电压

 

1号针脚的活动与其他针脚明显不同,其电压的波动就像是与主板进行数据发送的过程,故此,认定1号脚为Tx端。


2号脚和3号脚的电压测量结果极为接近,但是仍有足够的差异区分他们。3号脚,电压稳定在3.3V,表明其为 VCC;2号脚电压仅是略低与VCC,故为Rx(仅剩的选择)。特别注意,如上图所示,尽管连接USB UART转换器并不需要用到3号脚,我们测试该脚仅仅是为了消除其为Tx 或 Rx 的可能性。



控制台连接



确定J17的针脚后,用USB UART转换器连接。注意,主板上的Rx 接转换器的Tx ,如下图所示:


 

      

接下来,我打开了一个终端并开启了一个screen会话,波特率设置为上面第一幅截屏所示是一致:

screen /dev/ttyUSB0 115200 8N1


 这样,我就成功获得了控制台的访问权,并且无需密码哦!



Boothloader



成功连接上控制台后,我还想看下它的bootloader。于是,我重启设备:


通过与U-boot交互,我得以了解更多有关主板和内存的信息:

      

通过对硬件底层的访问,我们能够看到更多在启动过程的信息。例如,系统控制台消息输出stdout:

      

由图可知,Telnet服务在系统启动时随之启动,只是在载入OBi 服务后被kill掉了(由上篇文章中的脚本部分可知)。


接下来>>>


现在,我已获得控制台的root访问权限,我希望进一步深入探究其运行的服务和obiapp 二进制文件。相关内容,敬请期待本文第三部分!





本文由看雪翻译小组 StrokMitream 编译,来源Randy Westergren

转载请注明来自看雪社区

热门阅读


点击阅读原文/read,

更多干货等着你~


您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存